# DISEÑO DE UN BANCO DE **REGISTROS PARA UN PROCESADOR MIPS**

Práctica 1 (1ª sesión)



Arquitectura y Organización de Computadores 2 2º Grado Ingeniería Informática

Luis M. Ramos luisma@unizar.es

Alejandro Valero alvabre@unizar.es

briz@unizar.es

José Luis Briz Javier Resano jresano@unizar.es



Escuela de

Ingeniería y Arquitectura

**Universidad** Zaragoza



## 1 RESUMEN

En esta práctica vamos a diseñar un banco de registros para un procesador MIPS. Seguiremos un procedimiento de diseño modular, utilizando bloques combinacionales: registros, multiplexores y decodificadores. Una vez diseñado, comprobaremos su correcto funcionamiento y realizaremos un análisis temporal.

**Al entrar al laboratorio** coloca el **trabajo previo del apartado 2.1** encima de la mesa, de forma visible. Antes de empezar a trabajar con Logisim conéctate a Moodle desde uno de los equipos del laboratorio y realiza el **contrato de prácticas** y el **control de asistencia a la sesión**.

La práctica finaliza cuando el banco de registros funciona correctamente y han sido entregados a través de *Moodle* el circuito del apartado 2.2.h y los resultados del apartado 3.

### 2 DISEÑO DE UN BANCO DE REGISTROS 32x32

#### 2.1 TRABAJO PREVIO: PRIMEROS PASOS CON LOGISIM Y DISEÑO MODULAR

- a) Lee el recurso "Primeros pasos con Logisim" y ve el video "Logisim Beginner's Tutorial", disponibles en Moodle.
- b) Diseña sobre papel un banco de 4 registros de 32 bits (BR4), utilizando cuatro registros de 32 bits, dos multiplexores MUX 4:1x32 y un decodificador DECOD 2:4. El banco de registros debe permitir dos lecturas y una escritura en cada ciclo. En las entradas RA y RB se indica qué registros se quieren leer, obteniéndose los datos en busA y busB. Si RegWr=1 el dato en busW se escribirá en el registro RW en el flanco ascendente de final de ciclo.
- c) Diseña un banco de 32 registros de 32 bits (BR32) utilizando 8 BR4, dos MUX 8:1x32 y un DECOD 3:8. Recuerda que debe permitir dos lecturas y una escritura en cada ciclo. Utiliza los mismos nombres en entradas y salidas que en el BR4.

#### 2.2 Trabajo en el laboratorio: diseño con Logisim

- a) Coloca 4 registros (carpeta de componentes *Memoria*) en una hoja de Logisim. Configúralos como registros de 32 bits (*propiedades/bits de datos*). Coloca un DECOD 2:4 (carpeta *Plexores/Decodificador* y *propiedades/seleccionar bits* → 2) cuyas salidas controlen los permisos de escritura de los registros (en). Interconecta las señales de *reset*, reloj y de entrada de datos.
- b) Coloca dos MUX 4:1x32 (*Plexores/Multiplexor, propiedades/seleccionar bits* → 2, *propiedades/Bits de Datos* → 32 y *propiedades/Include Enable?* → No) que seleccionen el dato de alguno de los registros.
- c) Coloca entradas para las señales **reset**, **reloj** y **busW**, **RA**, **RB**, **RW** y **RegWr**. Configúralas con el número de bits correcto (*propiedades/Bits De Datos*) y nómbralas (*propiedades/etiqueta*). Conéctalas donde corresponda. Conecta salidas a los MUX, configúralas de 32 bits y nómbralas (**busA** y **busB**).
- d) Ya tenemos un banco de 4 registros. Comprueba que funciona correctamente realizando varias escrituras (**RW**, **busW**, **RegWr**), lecturas (**RA**, **RB**) y borrados (**reset**).

- e) Renombra el circuito como "BR4" (Clic en main /propiedades/Nombre Del Circuito). Puedes cambiar la apariencia del encapsulado y la posición de los pines pulsando. Pulsa para volver al diseño del circuito.
- f) Añade un circuito nuevo (en el menú de componentes clic derecho en carpeta raíz y selecciona Añadir circuito). Nómbralo "BR32". Márcalo como circuito principal (Clic derecho en BR32". /Seleccionar Como Circuito Principal).
- g) Coloca 8 BR4. Añade un DECOD 3:8 para que la escritura se efectúe correctamente en uno de los 32 registros. Añade MUX 8:1x32 para que las dos lecturas se efectúen correctamente.
- h) Coloca entradas y salidas para todas las señales del banco de registros de 32 bits (también para la señal de reloj). Configúralas del número de bits adecuado. Utiliza separadores para separar los bits necesarios (Wiring/Separador) y conectarlos donde correspondan. Utiliza túneles (Wiring/Tunnel) para conectar señales a través de nombres.
- i) Cambia a modo simulación by realiza varias escrituras y lecturas en distintos registros. Para visualizar el valor de cada señal puedes añadir componentes Ver (Wiring/Ver) o directamente hacer clic en la señal. También puedes hacer doble clic en un BR4 para entrar en él y comprobar el contenido de los registros.
- j) Cuando todo funcione correctamente entrégalo a través del recurso Moodle "Entrega NIA-BR32".

# 3 ANÁLISIS TEMPORAL

- a) Realiza un análisis temporal de los bloques combinacionales (MUX 4:1, MUX 8:1, DECOD 2:4, DECOD 3:8), calculando el retardo de los caminos entre todas las entradas y salidas de cada bloque. Asume una implementación siguiendo la expresión  $Z=X_0*\overline{S_1}*\overline{S_0}+X_1*\overline{S_1}*S_0+\cdots$  para los MUX y  $Z_0=en*\overline{S_1}*\overline{S_0}$ ;  $Z_1=en*\overline{S_1}*S_0$ ; ... para los DECOD. Los retardos de las puertas utilizadas son:  $d_{\text{NOT}}=5$ ps;  $d_{\text{OR2-4}}=20$ ps;  $d_{\text{AND2-4}}=20$ ps;  $d_{\text{REG}}=50$ ps; tsetup $_{\text{REG}}=30$ ps. Ten en cuenta que disponemos de puertas OR de un máximo de 4 entradas.
- b) Identifica los caminos combinacionales que intervienen en la lectura del BR32 (RA→busA y REG→busA) y calcula sus retardos (d<sub>RA→busA</sub>, d<sub>busA</sub>). Ten en cuenta que los bits de RA tienen distintos caminos, y deberás obtener el retardo máximo de todos ellos.
- c) Identifica los caminos combinacionales que intervienen en la escritura del BR32 (RW→REG, busW→REG y RegWr→REG). ¿Con qué antelación al flanco de reloj tiene que establecerse el valor de cada entrada (tsetup<sub>RW</sub>, tsetup<sub>busW</sub>, tsetup<sub>RegWr</sub>)?
- d) Cuando tengas todos los retardos y los tiempos de *setup* introdúcelos a través del recurso "Análisis temporal BR32" de Moodle.